## How to access IP block memory addresses in Libero

Blog post: https://soceame.wordpress.com/2025/03/11/how-to-access-ip-block-memory-addressesin-libero/

Blog: <a href="https://soceame.wordpress.com/">https://soceame.wordpress.com/</a>

GitHub: <a href="https://github.com/DRubioG">https://github.com/DRubioG</a>

Last modification date: 11/03/25

To access the memory addresses that Libero assigns to the SmartDesign IP blocks, you must have the SmartDesign open.



Now, all you have to do is click the following icon in the top bar.



Clicking this button opens a tab showing all the memory addresses in the desired SmartDesign. The initial memory address, the allocated memory size, and the last memory address appear.



For example, it also has specific sections for peripherals connected to an interconnection block, such as an *AHB\_TO\_APB* to connect a data address bus (*AHB*) to a peripheral bus (*APB*).



These memory addresses can also be exported.



To export it, export it as JSON.



This JSON contains all the memory address information.

```
"title": "Memory Map Report",
"date": "Tue Jan 7 20:10:22 2025",
"project_name": "MPFS_DISCOVERY",
"project_location": "C:\\MPFS_DISCOVERY",
"SmartDesign name": "MPFS_DISCOVERY_KIT",
"Initiator/Bus/Bridge/Target OffsetAddress Range HighAddress":[
{"Node name":"FIC_0_PERIPHERALS_0/DMA_CONTROLLER:AXI4MasterDMA_IF",
"Component name": "DMA_CONTROLLER",
"Type":"Initiator",
     "Connected Node":[
         {"Node name": FIC_0_PERIPHERALS_0/DMA_INITIATOR: AXI4mmaster0",
         "Component name": "DMA_INITIATOR",
         "Type": "Bus",
              "Connected Node":[
         {"Node name": "MSS_WRAPPER_0:FIC_0_AXI4_TARGET",
         "Component name": "MSS_WRAPPER",
         "Offset Address": "0x0000 0000",
         "Range":"4GB",
"High Address":"0xFFFF_FFFF",
         "Type":"Target"
{"Node name":"FIC_3_PERIPHERALS_0/FIC_3_ADDRESS_GENERATION_1/APB_PASS_THROUGH_0:APB_INITIATOR",
"Component name": "APB_PASS_THROUGH",
"Type":"Initiator"
     e":"Initiator",
"Connected Node":[
         {"Node name":"FIC_3_PERIPHERALS_0/FIC_3_ADDRESS_GENERATION_1/FIC_3_0x4000_0xxx_0:APB3mmaster",
         "Component name": "FIC_3_0x4000_0xxx",
         "Type": "Bus",
              "Connected Node":[
         {"Node name": "PWM: APBslave",
         "Component name": "corepwm_CO",
         "Offset Address": "0x0000_0000",
         "Range":"256B",
"High Address":"0x0000 00FF"
```

You can see the memory addresses used.

dilps://st

```
{"Node name":"I2C A LO",
"Offset Address": "0x2010 A000",
"Range": "4KB",
"High Address":"0x2010_AFFF",
"Type":"Target"
},
{"Node name": "SPI B LO",
"Offset Address": "0x2010 9000",
"Range": "4KB",
"High Address": "0x2010 9FFF",
"Type": "Target"
{"Node name": "SPI A LO",
"Offset Address": "0x2010 8000",
"Range": "4KB",
"High Address": "0x2010 8FFF",
"Type": "Target"
},
{"Node name": "WDOG4 LO",
"Offset Address": "0x2010 7000",
"Range": "4KB",
"High Address": "0x2010 7FFF",
"Type": "Target"
},
{"Node name": "MMUART4 LO",
"Offset Address": "0x2010 6000",
"Range": "4KB",
"High Address": "0x2010 6FFF",
"Type": "Target"
```